<template>
  <el-dialog
    :append-to-body="true"
    :before-close="handleClose"
    :close-on-click-modal="false"
    :close-on-press-escape="false"
    :title="dialogData.title"
    :visible.sync="isDialog"
    width="600px"
  >
    <el-form
      ref="submitFormRef"
      :model="submitForm"
      :rules="submitFormRules"
      label-position="right"
      label-width="75px"
    >
      <el-form-item label="参数值" prop="value">
        <el-input
          v-model="submitForm.value"
          clearable
          placeholder="请输入参数值"
        ></el-input>
        <div>
          <span class="color-tips1">备注：{{ info.remark || "暂无" }}</span>
        </div>
      </el-form-item>
    </el-form>

    <div slot="footer">
      <el-button @click="handleClose">取消</el-button>
      <el-button
        :loading="isLoading.submit"
        type="primary"
        @click="handleSubmit"
      >
        确 定
      </el-button>
    </div>
  </el-dialog>
</template>

<script>
import { edit } from "@/api/param";

export default {
  name: "Edit",
  props: {
    info: {
      type: Object,
    },
  },
  data() {
    return {
      // 表单提交
      submitForm: {
        id: this.info.id,
        value: this.info.value,
      },
      // 表单验证
      submitFormRules: {
        id: [{ required: true, message: "请选择配置", trigger: "blur" }],
        value: [{ required: true, message: "请输入参数值", trigger: "blur" }],
      },
      // 数据
      dialogData: {
        title: "",
        type: 0,
      },
      // 加载状态
      isLoading: {
        submit: false,
      },
      // 是否弹窗
      isDialog: true,
    };
  },
  created() {
    this.dialogData.title = "修改" + "(" + this.info.name + ")";
  },
  methods: {
    // 提交
    handleSubmit() {
      this.$refs.submitFormRef.validate((valid) => {
        if (!valid) {
          return false;
        }
        this.isLoading.submit = true;
        edit(this.submitForm)
          .then(() => {
            this.isLoading.submit = false;
            this.$emit("close");
          })
          .catch(() => {
            this.isLoading.submit = false;
          });
      });
    },
    // 关闭
    handleClose() {
      this.$emit("close", "cancel");
    },
  },
};
</script>

<style lang="scss" scoped>
::v-deep .el-textarea textarea {
  font-family: "Microsoft YaHei", "微软雅黑", Arial, sans-serif;
}

::v-deep .tox-tinymce {
  min-height: 500px;
}

.image-box {
  width: 100%;
  height: 100%;

  img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    cursor: pointer;
  }
}
</style>
